import {
  getCategoriesById,
  getShops
} from '../../api/index.js'
Page({

  /**
   * 页面的初始数据
   */
  data: {
    id: 0,
    page: 0,
    limit: 20,
    shops: [],
    hasMore: true
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    this.setData({
      id: Number(options.id)
    })
    this.getCategoriesById()
    this.getShops()
  },
  handlePhoneMakeCall(e) {
    wx.makePhoneCall({
      phoneNumber: e.target.dataset.phone
    })
  },
  getCategoriesById() {
    getCategoriesById(this.data.id).then(res => {
      // console.log(res)
      wx.setNavigationBarTitle({
        title: res.data.name,
      })
    })
  },
  getShops() {
    // 节流
    if (this.data.hasMore !== true) return;
    ++this.data.page
    getShops({
      id: this.data.id,
      page: this.data.page,
      limit: this.data.limit
    }).then(res => {
      // console.log(res)
      // 判断数据请求是到达临界点，如果到达临界点把hasMore 设置为false
      if (res.data.length > 0) {
        this.setData({
          shops: [...this.data.shops, ...res.data]
        })
      } else {
        this.setData({
          hasMore: false
        })
      }
    })
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {
    this.setData({
      hasMore: true,
      shops: [],
      page: Math.floor(Math.random() * 3)
    })
    this.getShops()
    // 关闭下拉的黑窗口
    wx.stopPullDownRefresh()
  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {
    this.getShops()
  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})